package br.com.werp.regras.acesso.integracao;

import br.com.werp.regras.geral.integracao.MasterDAO;
import br.com.werp.regras.geral.util.Constantes;
import br.com.werp.regras.geral.vos.acesso.SetorEmpresaVO;

import java.sql.Connection;

import java.util.List;
import java.util.ResourceBundle;


/**
 * @author aledson
 * Criado em 10/11/2005
 */
public class SetorEmpresaDAO extends MasterDAO {
    private static SetorEmpresaDAO setorEmpresaDAO;

    /**
     * @param banco
     * @throws Exception
     */
    public SetorEmpresaDAO(String banco) throws Exception {
        super(banco);
    }

    /**
     * @return
     * @throws Exception
     */
    public static SetorEmpresaDAO getSetorEmpresaDAO()
        throws Exception {
        if (setorEmpresaDAO == null) {
            ResourceBundle bundle = ResourceBundle.getBundle(Constantes.CONFIG);
            setorEmpresaDAO = new SetorEmpresaDAO(bundle.getString(
                        Constantes.BANCO));
        }

        return setorEmpresaDAO;
    }

    /**
     * @param setorEmpresaVO
     * @return
     * @throws Exception
     */
    public List pesquisarSetorEmpresa(SetorEmpresaVO setorEmpresaVO)
        throws Exception {
        Connection conn = getConexao();

        try {
            String tabelas = "setor, empresa,setor_empresa";

            String where = "empr_id = stem_empresa  " +
                "and stor_id = stem_setor  ";

            if (setorEmpresaVO.getStor_id() != 0) {
                where += (" and stor_id = " + setorEmpresaVO.getStor_id());
            }

            if (setorEmpresaVO.getStem_empresa() != 0) {
                where += (" and stem_empresa = " +
                setorEmpresaVO.getStem_empresa());
            }

            if (!"".equals(setorEmpresaVO.getStor_descricao()) &&
                    (setorEmpresaVO.getStor_descricao() != null)) {
                where += (" and stor_descricao like '%" +
                setorEmpresaVO.getStor_descricao().toUpperCase() + "%'");
            }

            return preencheVO(conn, new SetorEmpresaVO(), tabelas, where);
        } finally {
            liberaConeccao(conn);
        }
    }
}
